Problem
学习小组
Time Limit:
Memory Limit:
Description
坑校准备鼓励学生参加学习小组。
共有个学生,个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学生考虑,规定一个学生最多参加个学习小组。财务处的大叔就没那么好了,他想尽量多收钱,因为每个学生参加学习小组都要交一定的手续费,不同的学习小组有不同的手续费。然而,事与愿违,校领导又决定对学习小组组织者进行奖励,若有个学生参加第i个学习小组,那么给这个学习小组组织者奖励元。在参与学生(而不是每个学习小组的人数总和)尽量多的情况下,求财务处最少要支出多少钱(若为负数,则输出负数)()。
Input
输入有若干行,第一行有三个用空格隔开的正整数。接下来的一行有个正整数,表示每个。第三行有个正整数,表示参加每个学习小组需要交的手续费。再接下来有一个行列的矩阵,表若第行列的数字是,则表示第个学生愿意参加第个学习小组,若为,则为不愿意。
Output
Sample Input
1 | 3 3 1 |
Sample Output
1 | -2 |
Hint
样例解释
参与学生最多为,每个学生参加一个学习小组,若有两个学生参加第一个学习小组,一个学生参加第二个学习小组(一定要有人参加第二个学习小组),支出为,可以证明没有更优的方案了。
数据范围与约定
的数据,。
标签:费用流
Solution
常规费用流建模。
建图:
每个学生为一个点,每个小组为一个点,共个点。
对每个学生,
流量 费用 (限制最多选个组)
流量 费用 (限制至少选一个组)
对每个组,
流量 费用 其中
即当前若有个人,再多一个人会带来的收益
学生和组之间则连边 流量 费用
跑小费流即可。
Code
1 |
|